| Architecture | Opcode<br>main:<br>extended | Register<br>specfiersx<br>length | Immediate<br>field<br>length | Typical instructions                                                                                                                                                          |
|--------------|-----------------------------|----------------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| microMIPS64  | 6                           | none                             | 10                           | Jumps                                                                                                                                                                         |
|              | 6                           | 1x5                              | 5                            | Register-register operation (32 registers) and Load using SP as base register; any destination                                                                                |
|              | 6                           | 1x3                              | 7                            | Branches equal/not equalzero. Loads using GP. as base.                                                                                                                        |
|              | 6:4                         | 2x3                              |                              | Register-register operation, rd/rs1, and rs2; 8 registers                                                                                                                     |
|              | 6:1                         | 2x3                              | 3                            | Register-register immediate, rd/rs1, and rs2; 8 registers                                                                                                                     |
|              | 6                           | 2x3                              | 4                            | Loads and stores; 8 registers                                                                                                                                                 |
|              | 6:4                         | 2x3                              |                              | Register-register operation, rd, and rs1; 8 registers                                                                                                                         |
|              | 6                           | 2x5                              |                              | Register-register operation; 32 registers.                                                                                                                                    |
| RV64GC       | 2:3                         |                                  | 11                           | Jumps                                                                                                                                                                         |
|              | 2:3                         | 1x3                              | 7                            | Branch                                                                                                                                                                        |
|              | 2:3                         | 1x3                              | 8                            | Immediate one source register.                                                                                                                                                |
|              | 2:3                         | 1x5                              | 6                            | Store using SP as base.                                                                                                                                                       |
|              | 2:3                         | 1x5                              | 6                            | ALU immediate and load using SP as base.                                                                                                                                      |
|              | 2:4                         | 2x5                              |                              | Register-register operation                                                                                                                                                   |
|              | 2:3                         | 2x3                              | 5                            | Loads and stores using 8 registers.                                                                                                                                           |
| Thumb-2      | 3:2                         | 2x3                              | 5                            | Shift, move, load/store word/byte                                                                                                                                             |
|              | 3:2                         | 1x3                              | 8                            | immediates: add, subtract, move, and compare                                                                                                                                  |
|              | 4:1                         | 1x3                              | 8                            | Load/store with stack pointer as base, Add to SP or PC,<br>Load/store multiple                                                                                                |
|              | 4:3                         | 3x3                              |                              | Load register indexed                                                                                                                                                         |
|              | 4:4                         |                                  | 8                            | Conditional branch, system instruction                                                                                                                                        |
|              | 4:12                        |                                  |                              | Miscellaneous: 22 different instructions with 12 formats (includes compare and branch on zero, pop/push registers, adjust stack pointer, reverse bytes, IF-THEN instruction). |
|              | 5                           | 1x3                              | 8                            | Load relative to PC                                                                                                                                                           |
|              | 5                           |                                  | 11                           | Unconditional branch                                                                                                                                                          |
|              | 6:1                         | 3x3                              |                              | Add/subtract                                                                                                                                                                  |
|              | 6:3                         | 1x4, 1x3                         |                              | Special data processing                                                                                                                                                       |
|              | 6:4                         | 2x3                              |                              | Logical data processing                                                                                                                                                       |
|              | 6:6                         | 1x4                              |                              | Branch and change instruction set (ARM vs. Thumb)                                                                                                                             |

FIGURE E.8 Instruction formats for the 16-bit instructions of microMIPS64, RV64GC, and Thumb-2. For instructions with a destination and two sources, but only two register fields, the instruction uses one of the registers as both source and destination. Note that the extended opcode field (or function field) and immediate field sometimes overlap or are identical. For RV64GC and microMIPS64, all the formats are shown; for Thumb-2, the Miscellaneous format includes 22 instructions with 12 slightly diff erent formats; we use the extended opcode field, but a few of these instructions have immediate or register fields.